Skip to contentMethod: static {...}
1: /*
2: * #%L
3: * *********************************************************************************************************************
4: *
5: * NorthernWind - lightweight CMS
6: * http://northernwind.tidalwave.it - git clone https://bitbucket.org/tidalwave/northernwind-src.git
7: * %%
8: * Copyright (C) 2011 - 2023 Tidalwave s.a.s. (http://tidalwave.it)
9: * %%
10: * *********************************************************************************************************************
11: *
12: * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
13: * the License. You may obtain a copy of the License at
14: *
15: * http://www.apache.org/licenses/LICENSE-2.0
16: *
17: * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
18: * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
19: * specific language governing permissions and limitations under the License.
20: *
21: * *********************************************************************************************************************
22: *
23: *
24: * *********************************************************************************************************************
25: * #L%
26: */
27: package it.tidalwave.northernwind.core.model.spi;
28:
29: import javax.annotation.Nonnull;
30: import lombok.extern.slf4j.Slf4j;
31:
32: /***********************************************************************************************************************
33: *
34: * This class holds a response object to be served. It's an abstract class: concrete descendants are supposed to
35: * create concrete responses adapting to a specific technology (e.g. Spring MVC, Jersey, etc...).
36: *
37: * @param <RESPONSE_TYPE> the produced response
38: *
39: * @author Fabrizio Giudici
40: *
41: **********************************************************************************************************************/
42: @Slf4j
43: public abstract class ResponseHolder<RESPONSE_TYPE> implements RequestResettable
44: {
45: /* package */ static final ThreadLocal<Object> THREAD_LOCAL = new ThreadLocal<>();
46: // private final ThreadLocal<ResponseType> THREAD_LOCAL = new ThreadLocal<ResponseType>();
47:
48: /*******************************************************************************************************************
49: *
50: * Start creating a new response.
51: *
52: * @return a builder for creating the response
53: *
54: ******************************************************************************************************************/
55: @Nonnull
56: public abstract ResponseBuilder<RESPONSE_TYPE> response();
57:
58: /*******************************************************************************************************************
59: *
60: * Returns the response for the current thread.
61: *
62: * @return the response
63: *
64: ******************************************************************************************************************/
65: @Nonnull
66: public RESPONSE_TYPE get()
67: {
68: return (RESPONSE_TYPE)THREAD_LOCAL.get();
69: }
70:
71: /*******************************************************************************************************************
72: *
73: * {@inheritDoc}
74: *
75: ******************************************************************************************************************/
76: @Override
77: public void requestReset()
78: {
79: THREAD_LOCAL.remove();
80: }
81: }